﻿Imports DTO
Imports DAO
Imports BUS

Public Class frmCapNhatLyDoThanhLy : Inherits DevComponents.DotNetBar.Office2007Form

    ' Hàm reset
    Private Sub Reset()
        'txtTenBangCap.Text = ""
        txtMaLyDo.Text = ""
        txtTenLyDoMoi.Text = ""
    End Sub

    ' Hàm kiểm tra dữ liệu khi thêm
    Private Function KiemTraDuLieuThem() As Boolean
        Return txtLyDo.Text <> ""
    End Function

    ' Khi nhấn nút Thoát
    Private Sub btnThoat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        Me.Close()
    End Sub

    ' Hàm thực hiện thêm bằng cấp
    Private Sub btnThem_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnThem.Click
        If KiemTraDuLieuThem() Then
            Dim kt As Integer = New CLyDoThanhLyBUS().ThemLyDoThanhLy(txtLyDo.Text)
            If (kt = (-1)) Then
                MessageBox.Show("Số lý do thanh lý không được vượt quá số lượng quy định", "Thong Bao")
                txtLyDo.Text = ""
                Return
            Else
                If (kt = 0) Then
                    MessageBox.Show("Tên lý do này đã tồn tại!", "Thong Bao")
                    txtLyDo.Text = ""
                    Return
                Else
                    MessageBox.Show("Đã thêm thành công!", "Thong Bao")
                    txtLyDo.Text = ""
                    Dim listlydothanhly As List(Of CLyDoThanhLyDTO) = New CLyDoThanhLyBUS().LayDanhSachLyDoThanhLySach()
                    dgvLyDoThanhLy.Rows.Clear()
                    stt = 1
                    For Each lydothanhly As CLyDoThanhLyDTO In listlydothanhly
                        dgvLyDoThanhLy.Rows.Add(stt, lydothanhly.Ma, lydothanhly.Ten)
                        stt += 1
                    Next
                    Return
                End If
            End If
        Else
            MessageBox.Show("Dữ liệu không hợp lệ!", "Thong Bao")
            txtLyDo.Focus()
            Return
        End If

    End Sub

    Private stt As Integer

    ' Hàm load
    Private Sub frmCapNhatLyDoThanhLy_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        stt = 1
        dtiNgayHienTai.Value = DateTime.Now

        ' Load danh sách lý do thanh lý vào trong datagridview:
        Dim listlydothanhly As List(Of CLyDoThanhLyDTO) = New CLyDoThanhLyBUS().LayDanhSachLyDoThanhLySach()
        dgvLyDoThanhLy.Rows.Clear()
        For Each lydothanhly As CLyDoThanhLyDTO In listlydothanhly
            dgvLyDoThanhLy.Rows.Add(stt, lydothanhly.Ma, lydothanhly.Ten)
            stt += 1
        Next
    End Sub


    ' Xử lý khi chọn vào dòng nào trong datagridview thì ta load nó lên cập nhật:
    Private Sub dgvLyDoThanhLy_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles dgvLyDoThanhLy.CellClick
        Dim index As Integer = e.RowIndex
        If index < 0 Then
            If txtMaLyDo.Text <> "" Then
                Reset()
            End If
            Return
        End If

        If (index >= dgvLyDoThanhLy.Rows.Count) Then
            If (txtMaLyDo.Text <> "") Then
                Reset()
            End If
            Return
        End If

        Dim dr As DataGridViewRow = dgvLyDoThanhLy.Rows(index)
        txtMaLyDo.Text = dr.Cells("clMaLyDo").Value
        txtTenLyDoMoi.Text = dr.Cells("clTenLyDo").Value

    End Sub


    Private Sub btnCapNhat_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnCapNhat.Click
        Dim lydothanhly As New CLyDoThanhLyDTO()
        If (Not Integer.TryParse(txtMaLyDo.Text, lydothanhly.Ma)) Then
            MessageBox.Show("Cần chọn lý do muốn cập nhật!", "Thong Bao")
            Return
        End If
        If (txtTenLyDoMoi.Text = "") Then
            MessageBox.Show("Cần nhập tên lý do mới để cập nhật!", "Thong Bao")
            txtTenLyDoMoi.Focus()
            Return
        End If

        lydothanhly.Ten = txtTenLyDoMoi.Text

        Dim lydothanhlybus As New CLyDoThanhLyBUS()
        Dim kq As Integer = lydothanhlybus.CapNhatLyDoThanhLy(lydothanhly)
        If (kq = 0) Then
            MessageBox.Show("Tên lý do này đã có", "Thong Bao")
            Return
        Else
            MessageBox.Show("Đã cập nhật thành công!", "Thong Bao")
            Reset()
            dgvLyDoThanhLy.Rows.Clear()
            Dim listlydothanhly As List(Of CLyDoThanhLyDTO) = New CLyDoThanhLyBUS().LayDanhSachLyDoThanhLySach()
            stt = 1
            For Each ldtl As CLyDoThanhLyDTO In listlydothanhly
                dgvLyDoThanhLy.Rows.Add(stt, ldtl.Ma, ldtl.Ten)
                stt += 1
            Next
            Return
        End If

    End Sub

End Class